\documentclass{article}
\usepackage[pdftex,active,tightpage]{preview}
\setlength\PreviewBorder{2mm}

\usepackage[utf8]{inputenc} % this is needed for umlauts
\usepackage[ngerman]{babel} % this is needed for umlauts
\usepackage[T1]{fontenc}    % this is needed for correct output of umlauts in pdf
\usepackage{amssymb,amsmath,amsfonts} % nice math rendering
\usepackage{braket} % needed for \Set
\usepackage{algorithm,algpseudocode}

\begin{document}
\begin{preview}
    Sei $S \subseteq V$ und $c:E\rightarrow\mathbb{R}_0^+$ die
    Kantengewichtsfunktion.
    Für $v \in V \setminus S$ sei:

        \begin{align*}
            c &:\mathcal{P}(V) \times V \rightarrow \mathbb{R}_0^+\\
        c(S,v) &:= \sum_{\substack{\Set{u,v} \in E\\ u \in S}} c(\Set{u,v})
        \end{align*}

    Sei nun $d: \mathcal{P}(V) \rightarrow V$ die Funktion, die den
    Knoten liefert, der am stärksten mit $S \in \mathcal{P}(V)$
    verbunden ist:
        \[d(S) := v \in V \setminus S: c(S, v) = \max(\Set{c(S,v) | v \in V \setminus S})\]

    \begin{algorithm}[H]
        \begin{algorithmic}
            \Function{StoerWagner}{Network $N(D, s, t, c)$}
                \State Graph $G_0 = D$
                \State Knoten $a,b,v$
                \State Phasenergebnisse $P$ \Comment{Speichert Schnitt und Gewicht}
                \For{($i=1$; $\;i<|V|$; $\;i$++)}
                    \State Knotenmenge $S_i \gets \Set{}$
                    \State $S_i$.add($S_i \in G_i$) \Comment{Wähle einen beliebigen Startknoten}
                    \While{$S_i \neq V_{i-1}$}
                        \State $v \gets$ \Call{d}{$S_i$}
                        \State $S_i$.add($v$)
                    \EndWhile

                    \State $a \gets v$
                    \State $b \gets$ \Call{d}{$\Set{a}$}
                    \State $V_i \gets$ \Call{Verschmelzen}{$V_{i-1}$, $a$, $b$}
                    \State $E_i \gets$ \Call{Verschmelzen}{$E_{i-1}$, $a$, $b$}
                    \State $G_i = (V_i, E_i)$
                    \State $P$.add($(a, V \setminus a)$, $c(a, V \setminus a)$)
                \EndFor

                \State \Return $P$.getMinimalCut()
            \EndFunction

            \Function{Verschmelzen}{Knotenmenge $V$, Knoten $a$, Knoten $b$}
                \State $V$.remove($a$)
                \State $V$.remove($b$)
                \State \Comment{TODO: was, wenn a und b schon Mengen sind?}
                \State $V$.add($\Set{a, b}$)
            \EndFunction

            \Function{Verschmelzen}{Kantenmenge $E$, Knoten $a$, Knoten $b$}
                \State \Comment{TODO: Kantengewichtsfunktion muss auch angepasst werden}
                \ForAll{Kante $e:=(x,y) \in E$}
                    \If{$x == a \lor x == b$}
                        \State $E$.remove($e$)
                        \State $E$.add($(\Set{a, b},y)$)
                    \ElsIf{$y == a \lor y == b$}
                        \State $E$.remove($e$)
                        \State $E$.add($(x, \Set{a, b})$)
                    \EndIf
                \EndFor
            \EndFunction
        \end{algorithmic}
    \caption{Algorithmus von Stoer und Wanger}
    \label{alg:seq1}
    \end{algorithm}
\end{preview}
\end{document}
